from1(X) -> cons2(X, from1(s1(X)))
length1(nil) -> 0
length1(cons2(X, Y)) -> s1(length11(Y))
length11(X) -> length1(X)
↳ QTRS
↳ DependencyPairsProof
from1(X) -> cons2(X, from1(s1(X)))
length1(nil) -> 0
length1(cons2(X, Y)) -> s1(length11(Y))
length11(X) -> length1(X)
LENGTH1(cons2(X, Y)) -> LENGTH11(Y)
LENGTH11(X) -> LENGTH1(X)
FROM1(X) -> FROM1(s1(X))
from1(X) -> cons2(X, from1(s1(X)))
length1(nil) -> 0
length1(cons2(X, Y)) -> s1(length11(Y))
length11(X) -> length1(X)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
LENGTH1(cons2(X, Y)) -> LENGTH11(Y)
LENGTH11(X) -> LENGTH1(X)
FROM1(X) -> FROM1(s1(X))
from1(X) -> cons2(X, from1(s1(X)))
length1(nil) -> 0
length1(cons2(X, Y)) -> s1(length11(Y))
length11(X) -> length1(X)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
LENGTH1(cons2(X, Y)) -> LENGTH11(Y)
LENGTH11(X) -> LENGTH1(X)
from1(X) -> cons2(X, from1(s1(X)))
length1(nil) -> 0
length1(cons2(X, Y)) -> s1(length11(Y))
length11(X) -> length1(X)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
LENGTH1(cons2(X, Y)) -> LENGTH11(Y)
LENGTH11(X) -> LENGTH1(X)
POL( LENGTH11(x1) ) = 3x1 + 2
POL( cons2(x1, x2) ) = x1 + 2x2 + 3
POL( LENGTH1(x1) ) = max{0, 2x1 - 1}
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
from1(X) -> cons2(X, from1(s1(X)))
length1(nil) -> 0
length1(cons2(X, Y)) -> s1(length11(Y))
length11(X) -> length1(X)
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
FROM1(X) -> FROM1(s1(X))
from1(X) -> cons2(X, from1(s1(X)))
length1(nil) -> 0
length1(cons2(X, Y)) -> s1(length11(Y))
length11(X) -> length1(X)